"""
URL configuration for library project.

The `urlpatterns` list routes URLs to views. For more information please see:
    https://docs.djangoproject.com/en/5.0/topics/http/urls/
Examples:
Function views
    1. Add an import:  from my_app import views
    2. Add a URL to urlpatterns:  path('', views.home, name='home')
Class-based views
    1. Add an import:  from other_app.views import Home
    2. Add a URL to urlpatterns:  path('', Home.as_view(), name='home')
Including another URLconf
    1. Import the include() function: from django.urls import include, path
    2. Add a URL to urlpatterns:  path('blog/', include('blog.urls'))
"""
import os

from django.contrib import admin
from django.urls import path, include, re_path
from rest_framework import permissions

# is_production = os.getenv('MY_ENV_VAR') == 'development'
is_production = os.getenv('MY_ENV_VAR') == 'production'

# 如果是开发环境，才导入 drf_yasg 和相关配置
if is_production:
    from drf_yasg import openapi
    from drf_yasg.views import get_schema_view

    schema_view = get_schema_view(
        openapi.Info(
            title="测试平台接口文档（swagger）",
            default_version='v1',
            description="测试平台接口文档（swagger）",
        ),
        public=True,
        permission_classes=[permissions.AllowAny]
    )

urlpatterns = [
    path('admin/', admin.site.urls),
    path('book/', include('books.urls')),

    # django-silk 路由
    path('silk/', include('silk.urls')),
]

# 如果是开发环境，才添加 drf-yasg 文档相关的路由
if is_production:
    urlpatterns += [
        # drf-yasg文档路由
        re_path(r'^swagger(?P<format>\.json|\.yaml)$', schema_view.without_ui(cache_timeout=0), name='schema-spec'),
        re_path(r'^swagger/$', schema_view.with_ui('swagger', cache_timeout=0), name='schema-swagger-ui'),
        re_path(r'^redoc/$', schema_view.with_ui('redoc', cache_timeout=0), name='schema-redoc'),
    ]